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Алгоритмы модификации деревьев 
для построения динамических 
предметных областей 


В статье рассматривается задача построения модели динамической многоуровневой предметной области 
для решения сложно структурированных задач. Предметная область такого класса задач формируется 
из различных информационных источников, распределенных в глобальной среде. Предлаг ается структура 
данных и алгоритмы модификации деревьев для построения динамических предметных областей. 


Введение 


При решении сложных задач возникает потребность в распределении работ между 
исполнителями с последующим объединением полученных результатов. На этапе деком- 
позиции центр может определить основные подзадачи, но ввиду естественных ограни- 
чений (компетенция, ресурсы, время) не способен найти их решение. Поэтому возникает 
проблема распределения подзадач между различными исполнителями, а после полу- 
чения частных результатов — проблема их согласования и интеграции [1]. Решение 
проблемы распределения подзадач состоит из четырех этапов: 

1) декомпозиция центром задачи $ на подзадачи (Зил, 312, Э21, ...); 

2) назначение подзадач исполнителям (Е1; Е; Ез; ...); 

3) решение подзадач исполнителями; 

4) синтез общего решения из частных результатов. 

Декомпозиция заключается в генерации множества подзадач, которые потенци- 
ально могут быть переданы другим исполнителям. Решение подзадачи исполнителем Е;, 
которому она передана, может состоять в полностью самостоятельном решении. 
Однако этот исполнитель также может решить проблему распределения, т.е. в свою 
очередь произвести декомпозицию подзадачи и привлечь других исполнителей. 
Процесс разбиения задачи на подзадачи может состоять из нескольких уровней. 

Синтез результата производится центром, который инициировал распределение 
задачи. Он собирает частные результаты своих «помощников» и формирует общий ре- 
зультат. Процесс формирования зависит от того, как исходная задача была разделена 
на подзадачи. Если декомпозиция, как отмечено выше, была многоуровневой, то и 
синтез результата будет многоуровневым. 

Таким образом, онтология предметной области задачи 5 строится в процессе 
совместной деятельности групп экспертов. Автоматизация этого процесса требует 
создания программной системы, которая должна поддерживать согласованную работу 
географически распределенных экспертов по формированию онтологии предметной 
области. В [2] показано, что соответствующая модель предметной области может 
быть описана следующим образом: 


тодУ=(Епеу, Ке!айоп, ЕКО |Р, 7,) (1) 
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Первые три компонента модели (1) представляют древовидный ациклический граф, 
вершиной которого является задача $, узлы определяют иерархию подзадач, дуги — уро- 
вень их вложенности. Терминальные узлы графа представлены фреймами Р (содер- 
жательная составляющая подзадачи) и 7, (технолого-образовательная составляющая). 

Предлагается алгоритм построения модели (1), состоящий из двух этапов. На первом 
из них необходимо построить статическую часть модели, представляющую иерархию 
задач целевой задачи. На втором — динамическую часть, подключая к терминальным 
узлам фреймы Р и Й. В результате формируется полная динамическая модель ПрО, 
представленная ациклическим графом с терминальными узлами, представленными 
фреймами. 

Свойство динамичности модели (1) обусловлено тем, что топология подзадач 
может меняться по мере подключения новых исполнителей. Это, в свою очередь, ведет 
к соответствующей модификации графа целевой задачи. 

Целью данной работы является разработка алгоритмического аппарата, позво- 
ляющего выполнять построение иерархического древовидного графа целевой задачи 
и его модификацию. Рассмотрим возможности реализации этого этапа на основе 
аппарата теории графов. 


Основные понятия и определения 


Пусть С(У, Е) — древовидный иерархический граф, представленный множеством 
вершин Е и множеством ребер У. Граф С будем называть динамическим, если за 
промежуток времени & возможен переход графа из состояния С\(У', Е^) в состояние 
С2(У?, Е>), причем множества (У У и(Е', Е”) соответственно не совпадают. 

Модификацией графа С назовем процесс перехода графа из состояния С' в 
момент времени { в состояние С? на момент времени ®, который может быть вызван 
выполнением некоторой последовательности двух типов операций на графе: слияние 
(НпК) и разбиение (са). В дальнейшем древовидный иерархический граф будем 
называть деревом. 

Операцию слияния (НиК(у, \)) определим как операцию, результатом выпол- 
нения которой является добавление дуги е@зе(у, уу) в дерево С. Здесь у — вершина 
дерева С, \ -— новая вершина. В результате выполнения операции слияния вершина 
у становится потомком вершины у (рис. 1). 


1 


8 9 


Рисунок 1 — Результат выполнения операции ДиА(4, 2) 


Операцию разбиения дерева С (сиКу, \)), определим как операцию, результатом 
выполнения которой является разбиение дерева С, содержащего дуту (У, \\) на два дерева, 
удалением дуги (у, \). Здесь у и м — смежные вершины одного дерева (рис. 2). 

Путь в дереве С определим как последовательность вершин У,е У, таких, что 
две любые последовательные вершины соединены хотя бы одной дугой из множества Е. 
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Рисунок 2 — Результат выполнения операции сиК, 2) 


Анализ результата выполнения операций Пик и сиё (рис. 2, 3) позволяет сделать 
вывод о том, что операция слияния вершин У и \ фактически приводит к формирова- 
нию пути от корня дерева к новой вершине (путь (1, 2, 4, 9) на рис. 2). Напротив, опе- 
рация сиё разбивает путь между вершинами у и М на два пути: от корня до вершины у 
(путь (1, 2) на рис. 2) и от вершины У до терминальной вершины (путь (4, 9) на рис. 2). 
Очевидно, что выполнение каждой из введенных операций в отдельности, а также вы- 
полнение некоторой последовательности таких операций, приводит к модификации 
исходного дерева С. А задачу модификации дерева можно свести к задаче модифи- 
кации путей дерева С. 

Введенные операции можно считать элементарными, однако их формальное опи- 
сание может быть представлено только в терминах элементарных операций над путями и 
операций, допустимых на множестве вершин и множестве ребер динамического дерева. 

На множестве вершин и множестве ребер дерева С введем следующий набор 
допустимых операций и определим правила их выполнения. 


Таблица 1 — Допустимые операции на графе 


№ Операция Параметры Результат выполнения операции 
Результатом выполнения операции является ссылка на 
предка вершины у. Если вершина у не имеет предка, то 
1 рагет уетех у 
она является корнем дерева и результатом выполнения 
операции является специальное значение пий (пусто). 
Операция возвращает ссылку на корень дерева, содер- 
р. оо уетех у р р у р р р 


жащего вершину у. 


Операция возвращает вес ребра ейее(у,рагеп(Ку)) и 
э с051 уетех у является допустимой для вершины, не являющейся 
корнем дерева. 


Операция возвращает ссылку на вершину, ближай- 
шую к гооКу), такую что ребро ейее(рагеп “м)) 
4 ттсоя уейех у имеет минимальный вес среди ребер на пути от у 
к корню гооКу). Операция допустима, если у не явля- 
ется корнем дерева. 


Операция обновления весов всех ребер на пути от 


5 иражше уетмех у, тех | вершины у к корню гооК») добавлением значения х 
к весу каждого ребра. 

6 рай уетмех у Возвращает путь, содержащий вершину ъ. 

7 реа4 рай р Возвращает начальную (первую) вершину пути р. 

8 ай рай р Возвращает хвост (последнюю вершину) пути р. 
Возвращает вершину, стоящую за вершиной у в пути 

9 аЙег уетех у рай»). Если вершина у — это концевая вершина пути 


рай(»), то возвращает специальное значение пи/. 
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Продолжение табл. 1 


№ Операция Параметры Результат выполнения операции 

10 рираме рай р, ге х __| Добавляет вес х к весу каждого ребра пути р. 
Объединяет пути р и 4 добавлением ребра едее(‘ай (р), 
реа (4)). Возвращает полученный путь. 

Разбивает путь рай(»), удалением из него ребер, инци- 
дентных у. Возвращает список /р, 4], где р — это часть 
И 5ри уетех у пути, включающая все вершины от йеай(рий(у)) до 
БеГоге(»), 4 — это часть пути, содержащая все вершины 
из айег(») до аШрий(»)). 


сопсшепие | рай р, д, гей х 


Таким образом, для решения задачи построения графа целевой задачи и после- 
дующей его модификации требуется разработать алгоритмы выполнения операций 
слияния и разбиения. Покажем далее, что введенная выше совокупность операций на 
дереве С является необходимой и достаточной для формального описания и после- 
дующей реализации алгоритмов модификации. Для этого разработаем структуру дан- 
ных для представления динамического дерева и опишем алгоритмы его модифика- 
ции в терминах введенных операций. 


Структура данных для представления 
динамического дерева 


Пусть на множестве вершин дерева С определен набор допустимых операций, 
обозначенных выше. Требуется разработать структуру данных для представления 
динамического дерева, обеспечивающую эффективную реализацию процедур разби- 
ения (дефрагментации) и слияния (интеграция фрагментов). 

Для решения поставленной задачи предлагается модификация динамической 
структуры, разработанной Тарьяном и Слейтором [4]. Выбор обоснован тем, что 
предлагаемая структура обеспечивает амортизационную сложность выполнения опера- 
ций на дереве — О([оз п), что является важным с точки зрения оценки временной эффек- 
тивности алгоритмов. 

Введем на множестве ребер Е дерева С два типа ребер (сплошные и пунктирные) 
по следующему правилу: из каждой вершины выходит не более одного сплошного 
ребра. В соответствии с этим все пути в графе также можно разделить на два типа: 
сплошной путь и разорванный путь (рис. 3). 


Рисунок 3 — Динамическое дерево 
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Тогда для каждой вершины у, которая является конечной вершиной сплошного 
пути, будем хранить указатель на ее родителя, из которого выходит пунктирное 
ребро. Как было показано выше, задачу модификации динамического графа можно 
свести к задаче модификации путей. В соответствии с предложенной структурой для 
представления динамического дерева, модификация пути может означать удлинение 
сплошного пути р и построение сплошного пути с начальной вершиной у и конечной 
вершиной рагеп(). Эти преобразования опишем двумя типами операций: 

1) зрИсе(ра р) — удлиняет сплошной путь, преобразовывая пунктирные ребра, 
заканчивающиеся в хвосте пути р, в сплошные (рис. 4). Возвращает полученный путь. 


Дм о 
№, 


Рисунок 4 — Результат выполнения операции зр|се 


2) ехрозе(уе\щех у) — создает сплошной путь с начальной вершиной у и конечной 
вершиной рагеп(»), преобразовывая пунктирные ребра в сплошные на всем пути от 
вершины у к гооцу). Возвращает результирующий сплошной путь (рис. 5). 


Рисунок 5 — Результат выполнения операции ехрозе 


Опишем алгоритмы выполнения операций 5р/се и ехрозе, используя запись на 
псевдокоде в нотации Дейкстры. 

1. Алгоритм выполнения операции 5рйсе: на входе алгоритма — разорванный 
путь р, содержащий пунктирные ребра; на выходе — сплошной путь. 


ЕапсЕ1оп зр11се (ра®В р): 
уегЕех и; ра В «а, г; геа1 х, у, 
м := арагеп® (%а11(р)); 
[аа г, х, У |] := $р11 (у); 
ТЕ 
Я < > па11 арагепе (а11 (а)):=\; 
Р := сопсажепаее (р, раеВ (у), асоз+($а11(р))); 


1Е г = п111 гебагп р; 

г < > па11 сопсафепаее(р, г, у); 
#1 
еп зр11се; 
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2. Алгоритм выполнения операции ехробе: на входе алгоритма — вершина у, на 
выходе — сплошной путь от вершины у к гоо{К»). 


ЕипсЕ1оп ехрозе (уег%ех п); 

рафЬ р, а, г; геа1 х, У; 

[а х, х, У | := $р11% (1); 

1Е а < > па11 арагепе ($а11(а)):=\; Е:; 


1Е г=па11 р :=раеВ (у); 
г< >па11 р:=сопсакепа*е (ра®Ъ (\),г,у) 
21; 


Чо аригепЕ ($а11(р)) < > па11 р := зр11се(р) оа; 
гебагп р; 
епа ехрозе; 


Алгоритмы модификации динамического дерева 


Представленная реализация алгоритмов модификации путей в дереве С, а также 
приведенный набор допустимых операций позволяют сформулировать в терминах этих 
операций необходимые алгоритмы для построения и модификации динамического 
дерева: определение родителя вершины у, поиск корня дерева, слияние деревьев и 
разбиение (декомпозиция) дерева. 

1. Поиск родителя вершины у: на входе алгоритма — вершина дерева у, на вы- 
ходе — непосредственный родитель вершины у. 


ЕопсЕ1оп рагеп®(уег%ех У); 
1Е у = $а11 (раб (\)) гебагп арагеп® (у); 
1Е \< > $а11 (рафЪ (У)) гебагп аЁег(\); 
еп рагеп®; 


2. Определение корня дерева: на входе алгоритма — вершина ъ, на выходе -— ко- 
рень дерева, которому принадлежит вершина у 


ЕапсЕ1оп гоо®(уег*ех \%); 
гебагп а11 (ехрозе (\)) 
еп гоое; 


3. Алгоритм слияния деревьев: на входе алгоритма — вершины у и у», на выходе — 
дерево, полученное слиянием двух деревьев за счет добавления дуги (у, у). 


ргосеаиге 1110К (уегеех У, м, геа1 х); 
сопсафепа*е (ра ®Ъ (у), ехрозе (и), х) 
епа 1110к; 


4. Алгоритм разбиения (декомпозиции) дерева: на входе алгоритма — вершина у: 
на выходе — два фрагмента исходного дерева, полученные удалением дуги (у, айеку)). 


Еапсе1оп сиё (уег*%ех %); 
рафеь р, ч; геа1 х, У; 
ехрозе (\); 


[рР,9,х,Уу] := 5р11%(\); 
Яригепе (\) := пи11; 
гееагп у 

епа сое; 
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Выводы 


В работе рассмотрен класс задач, решение которых формируется в результате 
совместной деятельности групп экспертов (исполнителей). Для решения задачи постро- 
ения графа целевой задачи и последующей его модификации разработан понятийный 
и алгоритмический аппарат. Предложена структура данных для представления дина- 
мического дерева, введен набор допустимых операций и разработаны алгоритмы мо- 
дификации дерева, описанные в терминах допустимых операций. Представленные 
алгоритмы могут быть использованы для создания программной системы, обеспечи- 
вающей согласованную работу территориально распределенных групп экспертов по 
формированию предметной области сложно структурированных задач. 
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В.В. Краснопрошин, А.В. Карканща 

Алгоритми модиф!кацй дерев для побудови динамчних предметних областей 

У статт! розглядаеться задача побудови модел! динамично! багатор1внево! предметно! област! для 
розв’язання складно структурованих задач. Предметна область такого класу задач формуеться з разних 
1нформащйних джерел, розподмених у глобальному середовищ!. Пропонуеться структура даних й 
алгоритми модифлкаци дерев для побудови динам!чних предметних областей. 


Г.Г. Ктазпоргозйт, А.Т. Кагкапиза 

Асогйт$ Мод сайоп 01 Тгее$ 0 Сгезе а Рупапис Зи ес отат 

ТЬе рарег 4езстез а рго ет оЁ сопзигасйп® то4е| оЁ 4упапис ти @-1еуе| зиб]есё дотала Юг ‘азК$ миВ 
сотрИсайе4 зиисяхе. ТВе зиБ]есё доташ ог Фезе 1азКз Ваз Бееп Кюптед Нот а уамебу ог шЮппаНоп 
зоигсез, 415 оие4 ш фе 21оБа] епупоптеп". А даа згасваге ап а]2ог $ по@Йсайоп оЁ геез {0 сгеже 
а 4упапис заб]ес( дотла аге ргезещечд. 


Статья поступила в редакцию 01.07.2010. 
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